/*
  学习目标：模拟路由实现
*/
import React from 'react';

export default class App extends React.Component {
  // 1. 声明数据保存url路径
  state = {
    url: '/home',
  };

  // 3. 监听url路径的变化， 实时更新state.url
  // cdm
  componentDidMount() {
    window.addEventListener('hashchange', () => {
      const { hash } = window.location;
      const url = hash.slice(1);
      this.setState({ url });
    });
  }

  render() {
    const { url } = this.state;
    return (
      <div>
        <h1>app组件</h1>
        <ul>
          <li>
            <a href="#/home">首页</a>
          </li>
          <li>
            <a href="#/my">我的音乐</a>
          </li>
          <li>
            <a href="#/friend">我的朋友</a>
          </li>
        </ul>
        {/*  // 2. 条件渲染 */}
        {url === '/home' && <Home />}
        {url === '/my' && <MyMusic />}
        {url === '/friend' && <Friend />}
      </div>
    );
  }
}

function Home() {
  return <h1>我是首页组件</h1>;
}

function MyMusic() {
  return <h1>我是我的音乐件</h1>;
}

function Friend() {
  return <h1>我是朋友组件</h1>;
}
